Source File
api_op_WriteGetObjectResponse.go
Belonging Package
github.com/aws/aws-sdk-go-v2/service/s3
// Code generated by smithy-go-codegen DO NOT EDIT.
package s3
import (
awsmiddleware
s3cust
smithy
smithyhttp
)
// Passes transformed objects to a GetObject operation when using Object Lambda
// access points. For information about Object Lambda access points, see
// Transforming objects with Object Lambda access points
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/transforming-objects.html)
// in the Amazon S3 User Guide. This operation supports metadata that can be
// returned by GetObject
// (https://docs.aws.amazon.com/AmazonS3/latest/API/API_GetObject.html), in
// addition to RequestRoute, RequestToken, StatusCode, ErrorCode, and ErrorMessage.
// The GetObject response metadata is supported so that the WriteGetObjectResponse
// caller, typically an Lambda function, can provide the same metadata when it
// internally invokes GetObject. When WriteGetObjectResponse is called by a
// customer-owned Lambda function, the metadata returned to the end user GetObject
// call might differ from what Amazon S3 would normally return. You can include any
// number of metadata headers. When including a metadata header, it should be
// prefaced with x-amz-meta. For example, x-amz-meta-my-custom-header:
// MyCustomValue. The primary use case for this is to forward GetObject metadata.
// Amazon Web Services provides some prebuilt Lambda functions that you can use
// with S3 Object Lambda to detect and redact personally identifiable information
// (PII) and decompress S3 objects. These Lambda functions are available in the
// Amazon Web Services Serverless Application Repository, and can be selected
// through the Amazon Web Services Management Console when you create your Object
// Lambda access point. Example 1: PII Access Control - This Lambda function uses
// Amazon Comprehend, a natural language processing (NLP) service using machine
// learning to find insights and relationships in text. It automatically detects
// personally identifiable information (PII) such as names, addresses, dates,
// credit card numbers, and social security numbers from documents in your Amazon
// S3 bucket. Example 2: PII Redaction - This Lambda function uses Amazon
// Comprehend, a natural language processing (NLP) service using machine learning
// to find insights and relationships in text. It automatically redacts personally
// identifiable information (PII) such as names, addresses, dates, credit card
// numbers, and social security numbers from documents in your Amazon S3 bucket.
// Example 3: Decompression - The Lambda function S3ObjectLambdaDecompression, is
// equipped to decompress objects stored in S3 in one of six compressed file
// formats including bzip2, gzip, snappy, zlib, zstandard and ZIP. For information
// on how to view and use these functions, see Using Amazon Web Services built
// Lambda functions
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/olap-examples.html) in
// the Amazon S3 User Guide.
func ( *Client) ( context.Context, *WriteGetObjectResponseInput, ...func(*Options)) (*WriteGetObjectResponseOutput, error) {
if == nil {
= &WriteGetObjectResponseInput{}
}
, , := .invokeOperation(, "WriteGetObjectResponse", , , .addOperationWriteGetObjectResponseMiddlewares)
if != nil {
return nil,
}
:= .(*WriteGetObjectResponseOutput)
.ResultMetadata =
return , nil
}
type WriteGetObjectResponseInput struct {
// Route prefix to the HTTP URL generated.
//
// This member is required.
RequestRoute *string
// A single use encrypted token that maps WriteGetObjectResponse to the end user
// GetObject request.
//
// This member is required.
RequestToken *string
// Indicates that a range of bytes was specified.
AcceptRanges *string
// The object data.
Body io.Reader
// Indicates whether the object stored in Amazon S3 uses an S3 bucket key for
// server-side encryption with Amazon Web Services KMS (SSE-KMS).
BucketKeyEnabled bool
// Specifies caching behavior along the request/reply chain.
CacheControl *string
// This header can be used as a data integrity check to verify that the data
// received is the same data that was originally sent. This specifies the
// base64-encoded, 32-bit CRC32 checksum of the object returned by the Object
// Lambda function. This may not match the checksum for the object stored in Amazon
// S3. Amazon S3 will perform validation of the checksum values only when the
// original GetObject request required checksum validation. For more information
// about checksums, see Checking object integrity
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html)
// in the Amazon S3 User Guide. Only one checksum header can be specified at a
// time. If you supply multiple checksum headers, this request will fail.
ChecksumCRC32 *string
// This header can be used as a data integrity check to verify that the data
// received is the same data that was originally sent. This specifies the
// base64-encoded, 32-bit CRC32C checksum of the object returned by the Object
// Lambda function. This may not match the checksum for the object stored in Amazon
// S3. Amazon S3 will perform validation of the checksum values only when the
// original GetObject request required checksum validation. For more information
// about checksums, see Checking object integrity
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html)
// in the Amazon S3 User Guide. Only one checksum header can be specified at a
// time. If you supply multiple checksum headers, this request will fail.
ChecksumCRC32C *string
// This header can be used as a data integrity check to verify that the data
// received is the same data that was originally sent. This specifies the
// base64-encoded, 160-bit SHA-1 digest of the object returned by the Object Lambda
// function. This may not match the checksum for the object stored in Amazon S3.
// Amazon S3 will perform validation of the checksum values only when the original
// GetObject request required checksum validation. For more information about
// checksums, see Checking object integrity
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html)
// in the Amazon S3 User Guide. Only one checksum header can be specified at a
// time. If you supply multiple checksum headers, this request will fail.
ChecksumSHA1 *string
// This header can be used as a data integrity check to verify that the data
// received is the same data that was originally sent. This specifies the
// base64-encoded, 256-bit SHA-256 digest of the object returned by the Object
// Lambda function. This may not match the checksum for the object stored in Amazon
// S3. Amazon S3 will perform validation of the checksum values only when the
// original GetObject request required checksum validation. For more information
// about checksums, see Checking object integrity
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/checking-object-integrity.html)
// in the Amazon S3 User Guide. Only one checksum header can be specified at a
// time. If you supply multiple checksum headers, this request will fail.
ChecksumSHA256 *string
// Specifies presentational information for the object.
ContentDisposition *string
// Specifies what content encodings have been applied to the object and thus what
// decoding mechanisms must be applied to obtain the media-type referenced by the
// Content-Type header field.
ContentEncoding *string
// The language the content is in.
ContentLanguage *string
// The size of the content body in bytes.
ContentLength int64
// The portion of the object returned in the response.
ContentRange *string
// A standard MIME type describing the format of the object data.
ContentType *string
// Specifies whether an object stored in Amazon S3 is (true) or is not (false) a
// delete marker.
DeleteMarker bool
// An opaque identifier assigned by a web server to a specific version of a
// resource found at a URL.
ETag *string
// A string that uniquely identifies an error condition. Returned in the tag of
// the error XML response for a corresponding GetObject call. Cannot be used with a
// successful StatusCode header or when the transformed object is provided in the
// body. All error codes from S3 are sentence-cased. The regular expression (regex)
// value is "^[A-Z][a-zA-Z]+$".
ErrorCode *string
// Contains a generic description of the error condition. Returned in the tag of
// the error XML response for a corresponding GetObject call. Cannot be used with a
// successful StatusCode header or when the transformed object is provided in body.
ErrorMessage *string
// If the object expiration is configured (see PUT Bucket lifecycle), the response
// includes this header. It includes the expiry-date and rule-id key-value pairs
// that provide the object expiration information. The value of the rule-id is
// URL-encoded.
Expiration *string
// The date and time at which the object is no longer cacheable.
Expires *time.Time
// The date and time that the object was last modified.
LastModified *time.Time
// A map of metadata to store with the object in S3.
Metadata map[string]string
// Set to the number of metadata entries not returned in x-amz-meta headers. This
// can happen if you create metadata using an API like SOAP that supports more
// flexible metadata than the REST API. For example, using SOAP, you can create
// metadata whose values are not legal HTTP headers.
MissingMeta int32
// Indicates whether an object stored in Amazon S3 has an active legal hold.
ObjectLockLegalHoldStatus types.ObjectLockLegalHoldStatus
// Indicates whether an object stored in Amazon S3 has Object Lock enabled. For
// more information about S3 Object Lock, see Object Lock
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-lock.html).
ObjectLockMode types.ObjectLockMode
// The date and time when Object Lock is configured to expire.
ObjectLockRetainUntilDate *time.Time
// The count of parts this object has.
PartsCount int32
// Indicates if request involves bucket that is either a source or destination in a
// Replication rule. For more information about S3 Replication, see Replication
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/replication.html).
ReplicationStatus types.ReplicationStatus
// If present, indicates that the requester was successfully charged for the
// request.
RequestCharged types.RequestCharged
// Provides information about object restoration operation and expiration time of
// the restored object copy.
Restore *string
// Encryption algorithm used if server-side encryption with a customer-provided
// encryption key was specified for object stored in Amazon S3.
SSECustomerAlgorithm *string
// 128-bit MD5 digest of customer-provided encryption key used in Amazon S3 to
// encrypt data stored in S3. For more information, see Protecting data using
// server-side encryption with customer-provided encryption keys (SSE-C)
// (https://docs.aws.amazon.com/AmazonS3/latest/userguide/ServerSideEncryptionCustomerKeys.html).
SSECustomerKeyMD5 *string
// If present, specifies the ID of the Amazon Web Services Key Management Service
// (Amazon Web Services KMS) symmetric customer managed key that was used for
// stored in Amazon S3 object.
SSEKMSKeyId *string
// The server-side encryption algorithm used when storing requested object in
// Amazon S3 (for example, AES256, aws:kms).
ServerSideEncryption types.ServerSideEncryption
// The integer status code for an HTTP response of a corresponding GetObject
// request. Status Codes
//
// * 200 - OK
//
// * 206 - Partial Content
//
// * 304 - Not
// Modified
//
// * 400 - Bad Request
//
// * 401 - Unauthorized
//
// * 403 - Forbidden
//
// * 404 -
// Not Found
//
// * 405 - Method Not Allowed
//
// * 409 - Conflict
//
// * 411 - Length
// Required
//
// * 412 - Precondition Failed
//
// * 416 - Range Not Satisfiable
//
// * 500 -
// Internal Server Error
//
// * 503 - Service Unavailable
StatusCode int32
// Provides storage class information of the object. Amazon S3 returns this header
// for all objects except for S3 Standard storage class objects. For more
// information, see Storage Classes
// (https://docs.aws.amazon.com/AmazonS3/latest/dev/storage-class-intro.html).
StorageClass types.StorageClass
// The number of tags, if any, on the object.
TagCount int32
// An ID used to reference a specific version of the object.
VersionId *string
noSmithyDocumentSerde
}
type WriteGetObjectResponseOutput struct {
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func ( *Client) ( *middleware.Stack, Options) ( error) {
= .Serialize.Add(&awsRestxml_serializeOpWriteGetObjectResponse{}, middleware.After)
if != nil {
return
}
= .Deserialize.Add(&awsRestxml_deserializeOpWriteGetObjectResponse{}, middleware.After)
if != nil {
return
}
if = addSetLoggerMiddleware(, ); != nil {
return
}
if = awsmiddleware.AddClientRequestIDMiddleware(); != nil {
return
}
if = smithyhttp.AddComputeContentLengthMiddleware(); != nil {
return
}
if = addResolveEndpointMiddleware(, ); != nil {
return
}
if = v4.AddUnsignedPayloadMiddleware(); != nil {
return
}
if = v4.AddContentSHA256HeaderMiddleware(); != nil {
return
}
if = addRetryMiddlewares(, ); != nil {
return
}
if = addHTTPSignerV4Middleware(, ); != nil {
return
}
if = awsmiddleware.AddRawResponseToMetadata(); != nil {
return
}
if = awsmiddleware.AddRecordResponseTiming(); != nil {
return
}
if = addClientUserAgent(); != nil {
return
}
if = smithyhttp.AddErrorCloseResponseBodyMiddleware(); != nil {
return
}
if = smithyhttp.AddCloseResponseBodyMiddleware(); != nil {
return
}
if = swapWithCustomHTTPSignerMiddleware(, ); != nil {
return
}
if = addEndpointPrefix_opWriteGetObjectResponseMiddleware(); != nil {
return
}
if = addOpWriteGetObjectResponseValidationMiddleware(); != nil {
return
}
if = .Initialize.Add(newServiceMetadataMiddleware_opWriteGetObjectResponse(.Region), middleware.Before); != nil {
return
}
if = addMetadataRetrieverMiddleware(); != nil {
return
}
if = addWriteGetObjectResponseUpdateEndpoint(, ); != nil {
return
}
if = addResponseErrorMiddleware(); != nil {
return
}
if = v4.UseDynamicPayloadSigningMiddleware(); != nil {
return
}
if = disableAcceptEncodingGzip(); != nil {
return
}
if = addRequestResponseLogging(, ); != nil {
return
}
return nil
}
type endpointPrefix_opWriteGetObjectResponseMiddleware struct {
}
func (*endpointPrefix_opWriteGetObjectResponseMiddleware) () string {
return "EndpointHostPrefix"
}
func ( *endpointPrefix_opWriteGetObjectResponseMiddleware) ( context.Context, middleware.SerializeInput, middleware.SerializeHandler) (
middleware.SerializeOutput, middleware.Metadata, error,
) {
if smithyhttp.GetHostnameImmutable() || smithyhttp.IsEndpointHostPrefixDisabled() {
return .HandleSerialize(, )
}
, := .Request.(*smithyhttp.Request)
if ! {
return , , fmt.Errorf("unknown transport type %T", .Request)
}
, := .Parameters.(*WriteGetObjectResponseInput)
if ! {
return , , fmt.Errorf("unknown input type %T", .Parameters)
}
var strings.Builder
if .RequestRoute == nil {
return , , &smithy.SerializationError{Err: fmt.Errorf("RequestRoute forms part of the endpoint host and so may not be nil")}
} else if !smithyhttp.ValidHostLabel(*.RequestRoute) {
return , , &smithy.SerializationError{Err: fmt.Errorf("RequestRoute forms part of the endpoint host and so must match \"[a-zA-Z0-9-]{1,63}\", but was \"%s\"", *.RequestRoute)}
} else {
.WriteString(*.RequestRoute)
}
.WriteString(".")
.URL.Host = .String() + .URL.Host
return .HandleSerialize(, )
}
func ( *middleware.Stack) error {
return .Serialize.Insert(&endpointPrefix_opWriteGetObjectResponseMiddleware{}, `OperationSerializer`, middleware.After)
}
func ( string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: ,
ServiceID: ServiceID,
SigningName: "s3",
OperationName: "WriteGetObjectResponse",
}
}
func ( *middleware.Stack, Options) error {
return s3cust.UpdateEndpoint(, s3cust.UpdateEndpointOptions{
Accessor: s3cust.UpdateEndpointParameterAccessor{
GetBucketFromInput: nopGetBucketAccessor,
},
UsePathStyle: .UsePathStyle,
UseAccelerate: .UseAccelerate,
SupportsAccelerate: true,
TargetS3ObjectLambda: true,
EndpointResolver: .EndpointResolver,
EndpointResolverOptions: .EndpointOptions,
UseARNRegion: .UseARNRegion,
DisableMultiRegionAccessPoints: .DisableMultiRegionAccessPoints,
})
}
The pages are generated with Golds v0.4.9. (GOOS=linux GOARCH=amd64)